热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

框图|中将_DA14531学习笔记经验总结

篇首语:本文由编程笔记#小编为大家整理,主要介绍了DA14531 学习笔记经验总结相关的知识,希望对你有一定的参考价值。 DA14531 学习笔记(二)经验总结 烧录 Fl

篇首语:本文由编程笔记#小编为大家整理,主要介绍了DA14531 学习笔记经验总结相关的知识,希望对你有一定的参考价值。



DA14531 学习笔记(二)经验总结

烧录


Flash

DA14531 为了降低成本和功耗,片内有32KB的OTP用于存放用户程序。

OTP只能烧录一次,为了方便调试,DA14531还支持外部flash。

使用外部flash时,首先需要根据硬件配置flash对应管脚


然后连接烧录就可以了


OTP

正式生产的时候就需要将外部flash去掉,烧录OTP。OTP烧录分为两部分,OTP header 和 固件


OTP header


  • 禁用jtag管脚

  • 使用OTP



    两个标志位需要选择yes


  • 设置MAC地址



    使用public 地址时,可以设置这里


  • OTP 长度



    上电后,需要使用DMA将OTP中的代码搬运到RAM(OTP不能跑代码),实测这里不填实际长度也可以(使用默认FFFFFFFF)



SDK 框架

DA14531 SDK不建议修改程序结构,也就是不建议修改mian函数。程序的执行流程如下


根据SDK框架的程序执行流程,用户可以在回调函数中添加自己的代码,而不需要直接修改mian函数。
回调函数在user_callback_config.h 文件中


MAC地址


静态随机地址

选择使用静态随机地址

默认静态随机地址生成函数,可以修改成自己的。

也可以在广播开始前修改

#include "llm.h"
#include "lld_util.h"
/* 使用静态地址时, 可以修改这里修改地址 */
llm_le_env.rand_add.addr[0] = 0x00;
llm_le_env.rand_add.addr[1] = 0x01;
llm_le_env.rand_add.addr[2] = 0x02;
llm_le_env.rand_add.addr[3] = 0x03;
llm_le_env.rand_add.addr[4] = 0x04;
llm_le_env.rand_add.addr[5] = 0xC9;

广播开始后修改地址

#include "llm.h"
#include "lld_util.h"
llm_le_env.rand_add.addr[0] = 0x01;
...
lld_util_set_bd_address(&llm_le_env.rand_add, ADDR_RAND);

公共地址

设置公共地址

公共地址默认设置

当OTP header 中的地址字节不是 0xFFFFFFFFFFFF 时,CFG_NVDS_TAG_BD_ADDRESS 的默认地址将会无效,工程使用OTP Header 中的MAC地址

程序可以通过 nvds_get_func 函数来获取公共地址

#include "llm.h"
/* 获取广播地址 */
uint8_t addr[6];
nvds_get_func(NVDS_TAG_BD_ADDRESS, NULL, addr);

低功耗

DA14531的框图如下所示,突出显示的红色框是放置保留存储器块的位置,其中包括SysRAM1(16kB),SysRAM2(12kB)和SysRAM3(20kB)。因此,总共有48kB的系统RAM可用。

DA14531 有三种休眠模式:


  1. 扩展睡眠模式

    在扩展休眠模式下,除 SysRAM、无线电域和外设域外设域外,系统域将断电,XTAL16M 时钟将停止。SysRAM 仍通电以保留数据,但无法访问。

    AON电源域为ON,用于将数据保存在保留RAM中,并为可以唤醒系统的模块(即唤醒计时器,正交解码器和BLE计时器)供电。

  2. 深度睡眠模式

    在深度睡眠模式下,为了进一步降低功耗,SysRAM也断电。其他电源域的状态与在扩展休眠模式下的状态相同。

    该器件可以使用时钟唤醒控制器、GPIO、RTC 警报或定时器1从深度睡眠中唤醒。

  3. 休眠休眠模式

    与前两种睡眠模式相比,在休眠模式下,PD_SLP(睡眠电源域)域将关闭。这意味着CRG(时钟和复位发生器)已关闭电源,这就是为什么此模式称为无时钟模式的原因。

    设备只能从配置为唤醒的 GPIO 中唤醒。用于将设备从休眠状态唤醒的可用GPIO P0_1,P0_2…P0_5。

睡眠模式由 SDK 中的#defines配置


  • Extended Sleep mode



    扩展睡眠模式可以选择 ARCH_EXT_SLEEP_OTP_COPY_ON 模式(代码RAM休眠,休眠后功耗会更低(只保留数据RAM),但是退出休眠时需要从OTP中将代码搬运到RAM,这部分操作也会耗电,如果休眠周期小于1s,不建议使用 ARCH_EXT_SLEEP_OTP_COPY_ON 模式)和 ARCH_EXT_SLEEP_ON模式。休眠时SDK会自动计算出RAM Blank使用情况,将未使用的RAM关闭。

    扩展睡眠模式可以通过RTC,Timer1, BLE timer唤醒,例如如果有BLE事件(如定时广播等),则BLE Timer可以唤醒DA14531.




    如果没有BLE唤醒,也可以设置额外的定时唤醒周期。


  • Deep Sleep mode

  • Hibernation mode



    深度睡眠模式和 休眠休眠模式比较类似,可以选择性关闭RAM 或者保留全部RAM,当关闭所有RAM后,休眠时更省电,但是唤醒时需要重新将代码从OTP加载到RAM。使用的时候需要定义相对的宏定义并定义唤醒方式,具体可以参考SDK中\\projects\\target_apps\\ble_examples\\prox_reporter 或者 扩展SDK中的hibernation 例子


    /**
    ****************************************************************************************
    *
    * @file user_proxr.h
    *
    * @brief Proximity Project application header file.
    *
    * Copyright (C) 2015-2020 Dialog Semiconductor.
    * This computer program includes Confidential, Proprietary Information
    * of Dialog Semiconductor. All Rights Reserved.
    *
    ****************************************************************************************
    */

    #ifndef _USER_PROXR_H_
    #define _USER_PROXR_H_
    /**
    ****************************************************************************************
    * @addtogroup APP
    * @ingroup RICOW
    *
    * @brief User Application entry point.
    *
    * @
    ****************************************************************************************
    */

    /*
    * INCLUDE FILES
    ****************************************************************************************
    */

    #include
    #include "gapc_task.h"
    /*
    * DEFINES
    ****************************************************************************************
    */

    /****************************************************************************************
    * Selects the sleep mode that the device will enter after advertising completion *
    * - CFG_APP_GOTO_DEEP_SLEEP Deep Sleep mode *
    * - CFG_APP_GOTO_HIBERNATION Hibernation mode (DA14531 only) *
    * - CFG_APP_GOTO_STATEFUL_HIBERNATION Stateful Hibernation mode (DA14531 only) *
    * Note: If none is defined, then system will enter the selected Extended sleep mode *
    * *
    * IMPORTANT: If CFG_APP_GOTO_STATEFUL_HIBERNATION is defined, CFG_STATEFUL_HIBERNATION *
    * shall be defined as well (in Options for Target 'DA14531' --> Asm --> *
    * Conditional Assembly Control Symbols --> Define:) *
    ****************************************************************************************/

    #undef CFG_APP_GOTO_DEEP_SLEEP
    #if defined (__DA14531__)
    #undef CFG_APP_GOTO_HIBERNATION
    #undef CFG_APP_GOTO_STATEFUL_HIBERNATION
    #if defined (CFG_APP_GOTO_HIBERNATION)
    /****************************************************************************************
    * Hibernation mode configuration *
    ****************************************************************************************/

    #define CFG_HIBERNATION_RAM1 PD_SYS_DOWN_RAM_OFF
    #define CFG_HIBERNATION_RAM2 PD_SYS_DOWN_RAM_OFF
    #define CFG_HIBERNATION_RAM3 PD_SYS_DOWN_RAM_OFF
    #define CFG_HIBERNATION_REMAP REMAP_ADDR0_TO_ROM
    #define CFG_HIBERNATION_PAD_LATCH_EN false
    #elif defined (CFG_APP_GOTO_STATEFUL_HIBERNATION)
    /****************************************************************************************
    * Stateful Hibernation mode configuration *
    ****************************************************************************************/

    #define CFG_STATEFUL_HIBERNATION_RAM1 PD_SYS_DOWN_RAM_ON
    #define CFG_STATEFUL_HIBERNATION_RAM2 PD_SYS_DOWN_RAM_ON
    #define CFG_STATEFUL_HIBERNATION_RAM3 PD_SYS_DOWN_RAM_ON
    #define CFG_STATEFUL_HIBERNATION_REMAP STATEFUL_HIBERN_REMAP_ADDR0_TO_RAM1
    #define CFG_STATEFUL_HIBERNATION_PAD_LATCH_EN false
    #endif // CFG_APP_GOTO_HIBERNATION
    #endif // __DA14531__
    #if defined (CFG_APP_GOTO_DEEP_SLEEP) && (defined (CFG_APP_GOTO_HIBERNATION) || defined (CFG_APP_GOTO_STATEFUL_HIBERNATION))
    #error "Config error: Can not define both CFG_APP_GOTO_DEEP_SLEEP and CFG_APP_GOTO_HIBERNATION/CFG_APP_GOTO_STATEFUL_HIBERNATION."
    #endif
    #if defined (CFG_SPI_FLASH_ENABLE) && (defined (CFG_APP_GOTO_HIBERNATION) || defined (CFG_APP_GOTO_STATEFUL_HIBERNATION))
    #error "Config error: Can not define both CFG_SPI_FLASH_ENABLE and CFG_APP_GOTO_HIBERNATION/CFG_APP_GOTO_STATEFUL_HIBERNATION."
    #endif
    #if defined (CFG_APP_GOTO_DEEP_SLEEP)
    /****************************************************************************************
    * Deep Sleep mode and Wake-up from Deep Sleep Configuration *
    * Selects the trigger mechanism to wake up from deep sleep. *
    * *
    * - CFG_DEEP_SLEEP_WAKEUP_POR - Wake up from POR pin *
    * *
    * - CFG_DEEP_SLEEP_WAKEUP_GPIO - Wake up from WakeUp Controller *
    * *
    * - CFG_DEEP_SLEEP_WAKEUP_RTC - Wake up from RTC Timer (only in DA14531) *
    * *
    * - CFG_DEEP_SLEEP_WAKEUP_TIMER1 - Wake up from Timer1 (only in DA14531) *
    * *
    * NOTE: *
    * A hardware reset or power cycle will always wake up the system from deep sleep. *
    ****************************************************************************************/

    #undef CFG_DEEP_SLEEP_WAKEUP_POR
    #define CFG_DEEP_SLEEP_WAKEUP_GPIO
    /****************************************************************************************
    * Deep sleep mode configuration *
    ****************************************************************************************/

    #define CFG_DEEP_SLEEP_RAM1 PD_SYS_DOWN_RAM_OFF
    #define CFG_DEEP_SLEEP_RAM2 PD_SYS_DOWN_RAM_OFF
    #define CFG_DEEP_SLEEP_RAM3 PD_SYS_DOWN_RAM_OFF
    #define CFG_DEEP_SLEEP_PAD_LATCH_EN false
    #if defined (__DA14531__)
    #undef CFG_DEEP_SLEEP_WAKEUP_RTC
    #undef CFG_DEEP_SLEEP_WAKEUP_TIMER1
    #endif
    #if defined (CFG_DEEP_SLEEP_WAKEUP_POR) && defined (CFG_DEEP_SLEEP_WAKEUP_GPIO)
    #error "Config error: Can not define both CFG_DEEP_SLEEP_WAKEUP_POR and CFG_DEEP_SLEEP_WAKEUP_GPIO."
    #endif
    #if !defined (CFG_DEEP_SLEEP_WAKEUP_POR) && !defined (CFG_DEEP_SLEEP_WAKEUP_GPIO) && \\
    !defined (CFG_DEEP_SLEEP_WAKEUP_RTC) && !defined (CFG_DEEP_SLEEP_WAKEUP_TIMER1)

    #error "Config error: At least one wake-up source has to be selected."
    #endif
    #endif
    /****************************************************************************************
    * Wake-up from Extended Sleep Configuration *
    * Selects the trigger mechanism to wake up from extended sleep. *
    * *
    * - CFG_EXT_SLEEP_WAKEUP_RTC - Wake up from RTC Timer (only in DA14531) *
    * *
    * - CFG_EXT_SLEEP_WAKEUP_TIMER1 - Wake up from Timer1 (only in DA14531) *
    * *
    * NOTE: *
    * If none is defined, then system will wake up from extended sleep by button press. *
    ****************************************************************************************/

    #undef CFG_EXT_SLEEP_WAKEUP_RTC
    #undef CFG_EXT_SLEEP_WAKEUP_TIMER1
    #if defined (CFG_EXT_SLEEP_WAKEUP_RTC) && defined (CFG_EXT_SLEEP_WAKEUP_TIMER1)
    #error "Config error: Can not define both CFG_EXT_SLEEP_WAKEUP_RTC and CFG_EXT_SLEEP_WAKEUP_TIMER1."
    #endif
    /*
    * FUNCTION DECLARATIONS
    ****************************************************************************************
    */

    /**
    ****************************************************************************************
    * @brief Enable push button. Register callback function for button press event.
    * Must be called in periph_init().
    ****************************************************************************************
    */

    void app_button_enable(void);
    /**
    ****************************************************************************************
    * @brief Function to be called on the advertising completion event.
    * @param[in] status GAP Error code
    ****************************************************************************************
    */

    void app_advertise_complete(const uint8_t status);
    #if (BLE_SUOTA_RECEIVER)
    /**
    ****************************************************************************************
    * @brief Function called when the SUOTAR status changes.
    * @param[in] suotar_event SUOTAR_START or SUOTAR_STOP
    ****************************************************************************************
    */

    void on_suotar_status_change(const uint8_t suotar_event);
    #endif // BLE_SUOTA_RECEIVER
    /**
    ****************************************************************************************
    * @brief Disconnection function.
    * @param[in] param Pointer to GAPC_DISCONNECT_IND message
    ****************************************************************************************
    */

    void user_app_on_disconnect(struct gapc_disconnect_ind const *param);
    /// @ APP
    #endif // _USER_PROXR_H_


ADC


ADC内部有一个分压电路,使用的时候需要注意。



学习笔记,如有错误,欢迎斧正。



推荐阅读
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细介绍了macOS系统的核心组件,包括如何管理其安全特性——系统完整性保护(SIP),并探讨了不同版本的更新亮点。对于使用macOS系统的用户来说,了解这些信息有助于更好地管理和优化系统性能。 ... [详细]
  • 文件描述符、文件句柄与打开文件之间的关联解析
    本文详细探讨了文件描述符、文件句柄和打开文件之间的关系,通过具体示例解释了它们在操作系统中的作用及其相互影响。 ... [详细]
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • 在前两篇文章中,我们探讨了 ControllerDescriptor 和 ActionDescriptor 这两个描述对象,分别对应控制器和操作方法。本文将基于 MVC3 源码进一步分析 ParameterDescriptor,即用于描述 Action 方法参数的对象,并详细介绍其工作原理。 ... [详细]
  • C++: 实现基于类的四面体体积计算
    本文介绍如何使用C++编程语言,通过定义类和方法来计算由四个三维坐标点构成的四面体体积。文中详细解释了四面体体积的数学公式,并提供了两种不同的实现方式。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • 本文详细解析了Python中的os和sys模块,介绍了它们的功能、常用方法及其在实际编程中的应用。 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • Linux设备驱动程序:异步时间操作与调度机制
    本文介绍了Linux内核中的几种异步延迟操作方法,包括内核定时器、tasklet机制和工作队列。这些机制允许在未来的某个时间点执行任务,而无需阻塞当前线程,从而提高系统的响应性和效率。 ... [详细]
  • 本文探讨了《魔兽世界》中红蓝两方阵营在备战阶段的策略与实现方法,通过代码展示了双方如何根据资源和兵种特性进行战士生产。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
author-avatar
刘家大宝688
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有